

CLAIMS

Claims Directed at a Method of Compiling a Simulation Object File

*Sub A7*  
1. A method of creating a behavioral model to allow non-atomic behavioral  
5 simulation of process blocks in an electronic design, the method comprising:

receiving hardware design code describing a process block; and

converting the hardware design code describing the process block to an assignment decision diagram (ADD) representation that is used by a simulator to simulate behavior of the process block and including one or more control nodes for maintaining control flow through  
10 the simulator, thereby creating one or more break points that allow the simulator to stop at associated points in the process block.

2. A method as recited in claim 1, wherein the assignment decision diagram representation comprises:

15 an assignment value portion representing the computation of values that are to be assigned to a storage unit of an output port, wherein the values are computed from current contents of storage units, input ports, or constants provided to the ADD;

an assignment condition portion connected as a data flow path representing the computation of a particular condition such that the end product of the condition

20 computation is a binary value that evaluates to either *TRUE* or *FALSE*;

an assignment decision node (ADN) that selects a value from a set of input values computed by the assignment value portion based upon the conditions computed by the assignment condition portion; and

25 an assignment target portion that is provided with the selected value from the corresponding ADN corresponding to the true ADN condition.

3. A method as recited in claim 1, wherein the control node is selected from the group comprising a query control node used to represent a conditional branch in a control flow, an evaluation/assignment control node used to represent an assignment

*Sub A7*  
operation, a null control node used as a place holder, and a suspend control node used to suspend execution of the process block.

4. A method as recited in claim 3, wherein the suspend control node is selected  
5 from the group comprising an event type suspend control node used to suspend execution of the process block pending a pre-determined future event and a delay type suspend control node used to suspend execution of the process block for a specific length of time.

5. A method as recited in claim 4, wherein the converting comprises:  
10 synthesizing a circuit level parse tree based upon operational characteristics and schematic layout of the circuit being simulated contained within the hardware design code, wherein the parse tree includes a process token and a process block token hierarchically interconnected such that the process token branches from the process block token, the process token identifying a simulation process to be carried out within the process block;

15 traversing the parse tree and allocating a process block structure in the simulation object file when the process block token is encountered;

further traversing the parse tree to determine if the process token is available;

determining the type of simulation process identified by process token;

converting the identified simulation process to a corresponding assignment

20 decision diagram; and

annotating the assignment decision diagram with a plurality of selected control nodes that are responsible for maintaining control flow through the simulator, wherein each of the control nodes has a next pointer that is used by the simulator to point to a next process step in the simulation process, and wherein the control nodes are stored in a 25 process block control node list contained within the object file.

6. A method as recited in claim 1, wherein the hardware design code is selected from the group comprising Verilog and VHDL.

*Sub A7*

7. A behavioral model, provided on a machine readable medium, allowing non-atomic behavioral simulation of one or more process blocks in an electronic design, the model comprising an assignment decision diagram representation of the process block
- 5 that can be used by a simulator to simulate behavior of the process block and including one or more control nodes for maintaining control flow through the simulator, thereby creating one or more break points that allow the simulator to stop at associated points in the process block.
- 10 8. A behavioral model, provided on a machine readable medium, as recited in claim 7, wherein the assignment decision diagram representation comprises:
- an assignment value portion representing the computation of values that are to be assigned to a storage unit of an output port, wherein the values are computed from current contents of storage units, input ports, or constants provided to the ADD;
- 15 an assignment condition portion connected as a data flow path representing the computation of a particular condition such that the end product of the condition computation is a binary value that evaluates to either *TRUE* or *FALSE*;
- an assignment decision node (ADN) that selects a value from a set of input values computed by the assignment value portion based upon the conditions computed by the
- 20 assignment condition portion; and
- an assignment target portion that is provided with the selected value from the corresponding ADN corresponding to the true ADN condition.
9. A method as recited in claim 7, wherein the control node is selected from
- 25 the group comprising a query control node used to represent a conditional branch in a control flow, an evaluation/assignment control node used to represent an assignment operation, a null control node used as a place holder, and a suspend control node used to suspend execution of the process block.

*Sub A7*

10. A method as recited in claim 9, wherein the suspend control node is selected from the group comprising an event type suspend control node used to suspend execution of the process block pending a pre-determined future event and a delay type suspend control node used to suspend execution of the process block for a specific length of time.
- 5
11. A method of compiling a simulation object file used by a simulator to simulate the operation of a digital circuit, wherein the simulation object file represents a behavioral model process block arranged to simulate the operation of the digital circuit by providing an output signal based upon an input signal, comprising:
- 10
- (a) synthesizing a circuit level parse tree based upon operational characteristics and schematic layout of the circuit being simulated, wherein the parse tree includes a process token and a process block token hierarchically interconnected such that the process token branches from the process block token, the process token identifying a simulation process to be carried out within the process block;
- 15
- (b) traversing the parse tree and allocating a process block structure in the simulation object file when the process block token is encountered;
- (c) further traversing the parse tree to determine if the process token is available;
- (d) determining the type of simulation process identified by process token;
- 20
- (e) converting the identified simulation process to a corresponding assignment decision diagram; and
- (f) annotating the assignment decision diagram (ADD) with a plurality of selected control nodes that are responsible for maintaining control flow through the simulator, wherein each of the control nodes has a next pointer that is used by the simulator
- 25
- to point to a next process step in the simulation process, and wherein the control nodes are stored in a process block control node list contained within the object file.

*Sub A'7*

12. A method as recited in claim 11, wherein the parse tree is formed of a plurality of sub-parse trees.
13. A method as recited in claim 11, wherein the assignment decision diagram comprises:
- an assignment value portion representing the computation of values that are to be assigned to a storage unit of an output port, wherein the values are computed from current contents of storage units, input ports, or constants provided to the ADD;
- an assignment condition portion connected as a data flow path representing the computation of a particular condition such that the end product of the condition computation is a binary value that evaluates to either *TRUE* or *FALSE*;
- an assignment decision node (ADN) that selects a value from a set of input values computed by the assignment value portion based upon the conditions computed by the assignment condition portion; and
- 15 an assignment target portion that is provided with the selected value from the corresponding ADN corresponding to the true ADN condition.
14. A method as recited in claim 11, wherein the control node is selected from the group comprising a query control node used to represent a conditional branch in a control flow, an evaluation/assignment control node used to represent an assignment operation, a null control node used as a place holder, and a suspend control node used to suspend execution of the process block.
15. A method as recited in claim 14, wherein the suspend control node comprises:
- 20 an event type suspend control node used to suspend execution of the process block pending a pre-determined future event.
- 25 16. A method as recited in claim 14, wherein the suspend control node comprises:

*Sub A*

a delay type suspend control node used to suspend execution of the process block for a for a specific length of time.

17. A method as recited in claim 16, further comprising:

- 5 (g) setting a next pointer of a last control node to a first control node; and  
(h) repeating (c) – (g) until no process tokens are available.

18. A method as recited in claim 17, wherein when it is determined that the process token identifies a process conditional, the converting the process further comprises:

- 10 allocating a query control node to the process block's control node list;  
recursively converting a true sub-parse tree to a corresponding true conditional ADD and a plurality of corresponding true eval CNs, wherein the true conditional ADD includes a true conditional ADN; and  
recursively converting a false sub-parse tree to a corresponding false conditional ADD  
15 and a corresponding false eval CN.

19. A method as recited in claim 18, wherein when it is determined that the process token identifies a process conditional, the annotating the ADD further comprises:

- 20 mapping the query CN to the true conditional ADN;  
setting each of the conditional inputs of the true ADN to appropriate ones of the true eval and false eval CNs;  
allocating a null CN to the process block CN list;  
setting a CN pointer associated with a last one of the plurality of true eval CNs and a CN pointer associated with a last one of the plurality of false eval CNs to the null CN; and  
25 identifying the query CN as a first CN and the null CN as a last CN.

20. A method as recited in claim 17, wherein when it is determined that the type of token is a process loop type token, the loop process having a loop entry condition and a loop

*Sub A'7*

exit condition suitable for entering and exiting, respectively, a corresponding loop expression and a loop body, the converting the process further comprises:

allocating a query CN to the process block CN list;

recursively converting a loop expression sub-parse tree to a corresponding loop

5 expression ADD; and

recursively converting a loop body sub-parse tree to a loop body ADD.

21. A method as recited in claim 20, wherein when it is determined that the process token identifies a process loop, the annotating the ADD further comprises:

10 annotating the loop expression ADD with appropriate loop expression control nodes;

mapping the query CN to the loop expression ADD;

annotating the loop body ADD with appropriate loop body control nodes;

returning a loop body first CN and a loop body last CN;

allocating a null CN;

15 pointing the loop body last CN to the null CN;

pointing the loop entry condition to the loop body first CN;

pointing the loop exit condition to the null CN; and

identifying the query CN as a first CN and the null CN as a last CN.

20 22. A method as recited in claim 17, wherein when it is determined that the type of token is a process suspend type token, the converting the process further comprises:

recursively converting a suspend sub-parse tree to a corresponding suspend ADD

23. A method as recited in claim 22, wherein when it is determined that the type of

25 token is a process suspend type token, the annotating the ADD further comprises:

determining the process suspend type;

if it is determined that the suspend type is a delay suspend type, then allocating a delay suspend CN to the process block CN list;

*Sub A'7*

if it is determined that the suspend type is an event suspend type, then allocating an event suspend CN to the process block CN list;

setting the allocated control node's reason to suspend pointer to the suspend ADD; and identifying the allocated CN as a first CN and a last CN.

5

24. A method as recited in claim 17, wherein when it is determined that the process is a process assignment, the converting the process further comprises:

recursively converting the assignment sub-parse tree to a corresponding assignment ADD.

10

25. A method as recited in claim 24, wherein when it is determined that the type of token is a process assignment type token, the annotating the assignment ADD further comprises:

allocating an assignment CN;

15

storing the allocated CN in the process block CN list;

mapping the CN to the assignment ADD; and

identifying the allocated CN as the first CN and the last CN.

20

26. A method as recited in claim 11, wherein the digital circuit being simulated is a programmable logic device.

#### Claims Directed at a Computer Program Product

25

27. A computer program project comprising computer program instructions provided on a computer readable medium, the computer program instructions specifying a method of compiling a simulation object file used by a simulator to simulate the operation of a digital circuit, wherein the simulation object file represents a behavioral model process

*Sub A<sup>7</sup>*

block arranged to simulate the operation of the digital circuit by providing an output signal based upon an input signal, the method comprising:

synthesizing a circuit level parse tree based upon operational characteristics and schematic layout of the circuit being simulated, wherein the parse tree includes a process token and a process block token hierarchically interconnected such that the process token branches from the process block token, the process token identifying a simulation process to be carried out within the process block;

traversing the parse tree and allocating a process block structure in the simulation object file when the process block token is encountered;

10 further traversing the parse tree to determine if the process token is available;

determining the type of simulation process identified by process token;

15 converting the identified simulation process to a corresponding assignment decision diagram; and

20 annotating the assignment decision diagram (ADD) with a plurality of selected control nodes that are responsible for maintaining control flow through the simulator, wherein each of the control nodes has a next pointer that is used by the simulator to point to a next process step in the simulation process, and wherein the control nodes are stored in a process block control node list contained within the object file.

28. An apparatus for creating a behavioral model to allow non-atomic behavioral simulation of process blocks in an electronic design, comprising:

a schematic editor for providing hardware design code that describes a process block;

25 a synthesizer coupled to the schematic editor for converting the hardware design code to an assignment decision diagram (ADD) representation;

an annotator coupled to the synthesizer for annotating the assignment decision diagram with one or more control nodes, and

*Sub A)*

a simulator for simulating the electronic design using the annotated assignment decision diagram, wherein the one or more control nodes are used for maintaining control flow through the simulator, thereby creating one or more break points that allow the simulator to stop at associated points in the process block.

5